| 3                                                                                     |
|---------------------------------------------------------------------------------------|
|                                                                                       |
|                                                                                       |
|                                                                                       |
|                                                                                       |
|                                                                                       |
| Divide the 32 bits of an imptruction into "fields"                                    |
|                                                                                       |
| La Conflict                                                                           |
| Desire to keep all the instructions length same                                       |
| Va                                                                                    |
| Desire to have a single instruction format.                                           |
|                                                                                       |
| Design Principle 3: Good design demands good compromises.                             |
| => RISC-V chooses to keep all the instruction length same; thereby requiring distinct |
| imptruction formats for different imptructions.                                       |
| Instruction Formats:                                                                  |
| R type => imptructions that use 3 registers. (Add, Sub, SLL, XOR, OR, AND,)           |
| I type => u u immediate and 2 registers. (Addi, SUI, SRLI, ORI, ANDI,                 |
| L) Stype => Storre imptraction                                                        |
|                                                                                       |
| R type imptraction  O                                                                 |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                 |
|                                                                                       |
| of each field has unique name and size.                                               |
| funct 7 RD2 RD1 funct 3 Rd Opcode                                                     |
| 7 bita 5 bita 3 bita 5 bita 7 bita                                                    |
| (Partially)                                                                           |
| Opcode = Demtoes the format of an instruction and instruction itself.                 |
| 12 d = Register destination operand                                                   |
| Paol = 4 source I 4                                                                   |
| 1202 = 4 SOUTREE 2 4                                                                  |
| funct 3 = 1 their combination tella                                                   |
| funetz = _ up which imstruction                                                       |
| to perform.                                                                           |



| Why?? => If you shift a 64 bit value                  |
|-------------------------------------------------------|
| more than 63 bits what happens?                       |
|                                                       |
| Shift Left and fill the positions with 0              |
| => We can perform multiplication                      |
| by 2 <sup>i</sup> uaing 511i.                         |
| SIII XII, XIO, Y                                      |
| $\sqrt{}$                                             |
| the value that will be                                |
| atored in XII in basicully,                           |
| val in X <sub>19</sub> # 2                            |
|                                                       |
| Clas CI Prost                                         |
| Shift Right Shift right and fill the positions with 0 |
| => We can perform division.                           |
| by 2 <sup>i</sup> waing spli.                         |
| Sr[i x11, x10, 4                                      |
|                                                       |
| the value that will be                                |
| atored in XII in basicully,                           |
| val in X10 / 24                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |
|                                                       |